草庐IT

python - 以只读模式从python打开sqlite3数据库

全部标签

ruby - 如何在 Ruby 中创建 CSV 文件的某些列的副本,其中一列中包含不同的数据?

我有一个名为“A.csv”的CSV文件。我需要使用“A.csv”中的数据生成一个名为“B.csv”的新CSV文件。我将使用“A.csv”中的列子集,并且必须将一列的值更新为“B.csv”中的新值。最终,我将使用B.csv中的这些数据针对数据库进行验证。如何创建新的CSV文件?如何将所需列的数据从A.csv复制到“B.csv”?如何为特定列附加值?我是Ruby的新手,但我能够读取CSV以获取数组或散列。 最佳答案 正如mikeb指出的那样,有文档-http://ruby-doc.org/stdlib-1.9.3/libdoc/csv/

ruby-on-rails - 如何在 RSpec 测试中打开 ActiveRecord 的 SQL 调试日志记录?

我对我的模型进行了一些RSpec测试,我想像在Rails服务器模式中看到的那样打开SQLActiveRecord日志记录。如何做到这一点?我开始我的测试RAILS_ENV=testbundleexecrspecmy/test_spec.rb谢谢 最佳答案 您可以尝试在某处的测试中将ActiveRecord记录器设置为标准输出。如果您正在使用rspec,也许在spechelper中?ActiveRecord::Base.logger=Logger.new(STDOUT) 关于ruby-on

ruby - 如何打开相对于主目录的文件

以下失败并显示Errno::ENOENT:没有这样的文件或目录,即使该文件存在:open('~/some_file')但是,我可以这样做:open(File.expand_path('~/some_file'))我有两个问题:为什么open不将波浪号处理为指向主目录?有没有比File.expand_path更巧妙的方法? 最佳答案 不确定这在Ruby1.9.3之前是否可用,但我发现最优雅的解决方案是使用Dir.home,它是核心的一部分。open("#{Dir.home}/some_file")

ruby - 什么命令打开 Ruby 的 REPL?

用什么命令打开Ruby的REPL?在Python中,您只需打开python,无需任何参数。 最佳答案 Ruby有多个REPL。标准库附带了一个名为IRb(用于InteractiveRuby)的REPL,它安装了一个名为irb的程序,但由于它是只是一个Ruby库,它也可以从Ruby代码中调用,而不仅仅是从shell中调用。在Rubinius,IRb也可以通过不带参数调用rbx程序来调用,就像在CPython中一样。还有一个非常好的REPL,叫做Pry,它会安装一个名为pry的程序,但由于它只是一个Ruby库,因此它也可以从Ruby代码

ruby - 从本地文件或 url 打开 IO 流

我知道有其他语言的库可以接受包含本地文件路径或url的字符串,并将其作为可读IO流打开。在ruby​​中有没有简单的方法来做到这一点? 最佳答案 open-uri是标准Ruby库的一部分,它将重新定义open的行为,以便您可以打开url以及本地文件。它返回一个File对象,因此您应该能够调用read和readlines等方法。require'open-uri'file_contents=open('local-file.txt'){|f|f.read}web_contents=open('http://www.stackoverfl

Ruby:如何通过 HTTP 将文件作为多部分/表单数据发布?

我想做一个HTTPPOST,看起来像从浏览器发布的HMTL表单。具体来说,发布一些文本字段和一个文件字段。发布文本字段很简单,net/httprdocs中有一个示例,但我不知道如何发布文件。Net::HTTP看起来不是最好的主意。curb看起来不错。 最佳答案 我喜欢RestClient.它封装了net/http等很酷的功能,比如多部分表单数据:require'rest_client'RestClient.post('http://localhost:3000/foo',:name_of_file_param=>File.new('

Ruby 用捕获的正则表达式模式替换字符串

我在将它翻译成Ruby时遇到了问题。这是一段JavaScript,它完全符合我的要求:functionget_code(str){returnstr.replace(/^(Z_.*):.*/,"$1")​​​​​​​​​​​​​​​​​​​​​​​​​​​;}我试过了gsub,sub,和replace但似乎没有一个能达到我的预期。以下是我尝试过的示例:"Z_sdsd:sdsd".gsub(/^(Z_.*):.*/){|capture|capture}"Z_sdsd:sdsd".gsub(/^(Z_.*):.*/,"$1")"Z_sdsd:sdsd".gsub(/^(Z_.*):.*/,

ruby - 如何在文件文本中搜索模式并将其替换为给定值

我正在寻找一个脚本来搜索文件(或文件列表)中的模式,如果找到,则用给定值替换该模式。想法? 最佳答案 免责声明:这种方法是对Ruby功能的简单说明,而不是用于替换文件中字符串的生产级解决方案。它容易出现各种故障情况,例如在崩溃、中断或磁盘已满的情况下丢失数据。此代码不适用于备份所有数据的快速一次性脚本。因此,请勿将此代码复制到您的程序中。这是一个快速的简短方法。file_names=['foo.txt','bar.txt']file_names.eachdo|file_name|text=File.read(file_name)ne

ruby-on-rails - 删除数据库表中的所有记录

如何在RubyonRails应用程序中删除我的一个数据库表中的所有记录? 最佳答案 如果您正在寻找一种无需SQL的方法,您应该能够使用delete_all。Post.delete_all或有条件Post.delete_all"person_id=5AND(category='Something'ORcategory='Else')"参见here获取更多信息。删除记录时没有先加载它们,这使得速度非常快,但会破坏计数器缓存等功能,这些功能依赖于在删除时执行的Rails代码。 关于ruby-o

ruby-on-rails - 你能在 Rails 中获取数据库用户名、密码、数据库名称吗?

我正在编写一个rake任务,它在Rails/ActiveRecord之外执行一些数据库工作。有没有办法获取database.yml中定义的当前环境的数据库连接信息(主机、用户名、密码、数据库名称)?我想得到它,这样我就可以用它来像这样连接......con=Mysql.real_connect("host","user","pw","current_db") 最佳答案 在Rails中,您可以创建一个配置对象并从中获取必要的信息:config=Rails.configuration.database_configurationhost